# Microcontroladores Semana 7

Semestre 2024-2 Por Kalun José Lau Gan

1

### Preguntas previas

- ¿Qué es el "BRA \$-2"?
  - Es un salto (branch) de dos posiciones de memoria (asumiendo cada posición de un byte) hacia atrás.
- ¿Va a dejar debates en el AV?
  - ¬¬
- La redacción del informe es de manera impersonal
- En I2C. ¿Cómo hacemos con las resistencias de pullup?
  - El PIC18F57Q43 posee pullups especialmente para dicha comunicación, revisar cap 19 del datasheet, de lo contrario se tendrán que colocar de manera externa en los puertos SDA y SCL.

### Agenda:

- Interrupciones en el PIC18F57Q43 (cap 11 del datasheet)
- Cap. 11 VIC (Vectorized Interrupt Controller)
- En la PC se aneja en base a Interrupt Requests (IRQs)

| IRQ | Usage                                        |  |  |  |  |
|-----|----------------------------------------------|--|--|--|--|
| 0   | system timer (cannot be changed)             |  |  |  |  |
| 1   | keyboard controller (cannot be changed)      |  |  |  |  |
| 2   | cascaded signals from IRQs 8-15              |  |  |  |  |
| 3   | second RS-232 serial port (COM2: in Windows) |  |  |  |  |
| 4   | first RS-232 serial port (COM1: in Windows)  |  |  |  |  |
| 5   | parallel port 2 and 3 or sound card          |  |  |  |  |
| 6   | floppy disk controller                       |  |  |  |  |
| 7   | first parallel port                          |  |  |  |  |
| 8   | real-time clock                              |  |  |  |  |
| 9   | open interrupt                               |  |  |  |  |
| 10  | open interrupt                               |  |  |  |  |
| 11  | open interrupt                               |  |  |  |  |
| 12  | PS/2 mouse                                   |  |  |  |  |
| 13  | math coprocessor                             |  |  |  |  |
| 14  | primary ATA channel                          |  |  |  |  |
| 15  | secondary ATA channel                        |  |  |  |  |

3

#### Interrupciones:

- Las interrupciones son **eventualidades** que detienen el flujo normal de operación del microcontrolador.
- Dos modos de operación: Vectorizado (MVECEN=ON) y el Legacy (MVECEN=OFF). MVECEN es un bit de configuración
- Todos los periféricos internos del microcontrolador (Timers, INTs externas, CCP, EUSART, A/D, comparadores analógicos, etc) pueden emitir interrupciones al CPU.
- Las banderas que indican la fuente de interrupción (xxxIF) deberán de bajarse manualmente una vez activados.
- Cuando bit de configuración MVECEN = OFF:
  - En el PIC18F57Q43 tenemos dos vectores de interrupción:
    - Alta Prioridad (0x0008)
    - Baja Prioridad (0x0018)
  - Las interrupciones vienen desactivadas por defecto (GIE=0 y todos los xxxIE=0).
  - Las prioridades están desactivadas por defecto (IPEN=0), si están desactivadas, todas van al 0x0008)
  - Al activarse las prioridades (IPEN=1) todas las fuentes estarán en alta (xxxIP=1)



| O            | RG 000000H    |  |  |  |  |
|--------------|---------------|--|--|--|--|
| b            | ra configuro  |  |  |  |  |
| 0            | RG 000008H    |  |  |  |  |
| _            | ra INT_ISR_HP |  |  |  |  |
|              |               |  |  |  |  |
| _            | RG 000018H    |  |  |  |  |
| bra INT_ISR_ |               |  |  |  |  |
| ORG 000020H  |               |  |  |  |  |
| configuro:   | ;             |  |  |  |  |
|              | ;             |  |  |  |  |
|              | ;             |  |  |  |  |

# Sobre el modo legacy en interrupciones

- Hay que tener en cuenta que para que funcione este modo, el bit de configuración MVECEN debe de estar en OFF (por defecto esta en ON)
- Tener en cuenta que si no se trabaja con prioridades (IPEN=0), todos los eventos se van a la dirección 000008H de la memoria de programa
- Si es que se activa las prioridades, por defecto todas las fuentes de interrupción están en alta prioridad
- Políticas de atención en prioridades:
  - Cuando un evento de alta prioridad y un evento de baja prioridad ocurren al mismo tiempo, el CPU primero atiende al de alta prioridad dejando en cola la atención del de baja prioridad, luego de atender la de alta prioridad se procede a atender al de baja prioridad.
  - Cuando ocurre un evento de de interrupción de alta prioridad, la atiendes y en ese momento recibes una de baja prioridad, el CPU sigue atendiendo al de alta prioridad y luego de terminar atiende la de baja prioridad.
  - Cuando ocurre un evento de baja prioridad, la atiendes y en ese momento ocurre una de alta prioridad, el CPU pone en pausa la atención del de baja prioridad y se va a atender al de alta prioridad, una vez terminado de atender la alta prioridad resume la atención del de baja prioridad.
  - Cuando se reciben dos interrupciones de la misma prioridad. El desarrollador tiene que decidir en el programa a quien atender primero.

5



#### La interrupción del Timer0

- Dependiendo del modo de trabajo:
  - Modo 8 bit: El evento de interrupción proviene de la comparación en igualdad entre TMR0H (valor de referencia de comparación) y TMR0L (registro de cuenta) - tmr0\_match
  - Modo 16 bit: El evento de interrupción proviene del desborde del registro de cuenta (65535 hacia 0) tmr0 overflow
- Tener en cuenta el valor que se le coloca en POSTSCALER, este dispositivo contará una cantidad de eventos (tmr0\_match o tmr0\_overflow) antes de activar la bandera TMROIF y que va desde 1:1 hasta 1:16.
  - Si POSTSCALER = 1:1, cada evento (tmr0 latch ó tmr0 overflow) activará TMR0IF
  - Si POSTSCALER = 1:2, cada dos eventos (tmr0\_match ó tmr0\_overflow) activará TMR0IF
- Cuando se levante la bandera (TMROIF), ésta deberá de bajarse manualmente.
- Para habilitar la interrupción del Timer0:
  - Activar TMR0IE, ubicado en el bit7 del registro PIE3
  - Activar GIE, ubicado en el bit7 del registro INTCONO
- De usar prioridades en las interrupciones del TimerO (modo legacy MVECEN=OFF):
  - Revisar el bit 7 (TMROIP) del registro IPR3, por defecto TMROIP=1 (alta prioridad)
  - Revisar bits IPEN, GIEH y GIEL del registro INTCONO

7

# Plantilla para manejar interrupción del TMRO en modo legacy (MVECEN=OFF) y sin prioridades (IPEN=0)

```
PROCESSOR 18F57Q43
        #include "cabecera.inc"
        PSECT upcino, class=CODE, reloc=2, abs
upcino:
                            _ Vector de alta pivrided
        ORG 000000H
        bra configuro
        ORG 000008H
        bra TMR0 ISR
        ORG 000100H
configuro:
        bsf PIE3, 7
                        ;Habilito interrupcion de TMR0
        bsf INTCONØ, 7 ;Habilito GIE
inicio: ;--
                        :Rutina principal
        bra inicio
TMRØ ISR:
                        ;Rutina de interrupcion de TMR0
                        ¡Lo que tiene que hacer cuando ocurrió una INT del TMR0 ¡Baja bandera TMR0IF
        bcf PIR7, 3
        retfie
                                retorno de donde viniste
        end upcino
```

# Plantilla para manejar interrupción del TMRO con MVECEN=1 (modo vectorizado)

```
PROCESSOR 18F57043
       #include "cabecera.inc"
      ORG 00003EH bra TMRO_ISR Lector of THROD organ INTBISE + Z (0x1F)
upcino:
       ORG 000100H
configuro:
       bsf PIE3, 7
                     ;Habilito interrupcion de TMR0
       bsf INTCON0, 7 ;Habilito GIE
                     ;Rutina principal
       bra inicio
TMR0_ISR: ;Rutina de interrupcion de TMR0
      ;Lo que tiene que hacer cuando ocurrió una INT del TMR0
bcf PIR7, 3 ;Baja bandera TMR0IF
       retfie
                             :retorno de donde viniste
       end upcino
```

9

### Las interrupciones externas INTO, INT1, INT2

- Interrumpen al CPU del microcontrolador, estas acciones provienen de pines externos (INT0, INT1 e INT2).
- Pines externos (por defecto RBO para INTO, RB1 para la INT1 y RB2 para INT2).
   Configurables su asignación por el PPS (registros INTxPPS, revisar cap 21).
- Pueden ser activos en alto (flanco ascendente) o activos en bajo (flanco descendente). Revisar bits INTOEDG, INT1EDG y INT2EDG (registro INTCONO).
- Los bits de habilitación de las interrupciones externas son INTOIE, INT1IE e INT2IE. Estos se encuentra en el grupo de registros PIEx
- Las banderas INTOIF, INT1IF e INT2IF deberán de bajarse (acción manual) cuando se activen. Se encuentran en el grupo de registros PIRx.
- Las prioridades (IPEN=1) todas son altas por defecto, si se quiere modificar alguna INTx para que sea baja prioridad, se tiene que ajustar INTOIP, INT1IP ó INT2IP según requerimientos. Se encuentran en el grupo de registros IPRx

#### Las interrupciones externas INTO, INT1, INT2

- En MVECEN=OFF (modo legacy) por defecto las tres interrupciones saltan al vector de alta prioridad (000008H) al ser activadas. Si se requiere pasar a baja prioridad (000018H) alguno de ellos se deberá activar la prioridad de las interrupciones (IPEN=1) y configurar los bits INTOIP, INT1IP e INT2IP según requerimientos. Se encuentran en el grupo de registros IPRx.
- Recordar que el GIE/GIEH (habilitador global, global alta prioridad), GIEL (habilitador global baja prioridad) e IPEN (habilitador de prioridades se encuentran en el registro INTCONO.

11

### Las interrupciones externas INTO, INT1, INT2

• En MVECEN=ON hay que tener en cuenta que las direcciones de los vectores de interrupción se tienen que calcular según tabla 11-1:

IVTBASE + (2 x Número de Vector)

- En MVECEN=ON las interrupciones INTO, INT1 e INT2 tienen sus propios vectores, al iniciar IVTBASE tiene valor 0 por lo que usando la fórmula anterior y según tabla 11-2 se obtienen las siguientes direcciones:
  - INTO 000010H
  - INT1 000060H
  - INT2 0000A0H



#### #include "cabecera.inc" Plantilla para manejar PSECT upcino,class=CODE,reloc=2,abs interrupciones externas ORG 000000H con MVECEN=OFF (modo ORG 000008H ;Vector de alta prioridad bra INTO ISR legacy) ORG 000018H ;Vector de baja prioridad bra INT1 ISR Se esta considerando que ORG 000100H onfiguro: INTO se encuentre en alta prioridad mientras que INT1 bsf PIE1, 0 bsf PIE6, 0 ;Habilito interrupcion de INT0 ;Habilito interrupcion de INT1 se encuentre en baja bsf INTCON0, ;Habilito IPEN prioridad. bsf INTCONO, 7 :Habilito GIEH bsf INTCONØ, 6 ;Habilito GIEL bcf IPR6, 0 ;Mando INT1 a baja prioridad Si IPEN=1, todas las fuentes inicio: ;--bra inicio de interrupción se ;Rutina principal encuentran en alta prioridad INTO\_ISR: ;Rutina de interrupcion de INT0 por defecto. ;Lo que tiene que hacer cuando ocurrió una INTO ;Baja bandera INT0IF bcf PIR1, 0 Para cambiar alguna fuente retfie de interrupción a baja ;retorno de donde viniste prioridad debemos de ubicar INT1 ISR: ;Rutina de interrupcion de INT1 ¡Lo que tiene que hacer cuando ocurrió una INT1 dicha fuente en los registros bcf PIR6, 0 ;Baja bandera INT1IF IPRx. retfie ;retorno de donde viniste

Plantilla para manejar interrupciones externas con MVECEN=ON (modo vectorizado)

```
PROCESSOR 18F57043
        #include "cabecera.inc"
        PSECT upcino, class=CODE, reloc=2, abs
upcino:
        ORG 000000H
                         ;Vector para la INT0
        bra INTO ISR
        ORG 000060H
                         ;Vector para la INT1
        bra INT1 ISR
        ORG 000100H
configuro:
        bsf PIE1, 0
bsf PIE6, 0
                         :Habilito interrupcion de INTO
                         ;Habilito interrupcion de INT1
        bsf INTCON0, 7 ;Habilito GIE
inicio: ;--
                         ;Rutina principal
        bra inicio
INTO_ISR:
                         ;Rutina de interrupcion de INT0
                        ;Lo que tiene que hacer cuando ocurrió una INT0
;Baja bandera INT0IF
        bcf PIR1, 0
        retfie
                                 ;retorno de donde viniste
INT1_ISR:
                         :Rutina de interrupcion de INT1
                         ;Lo que tiene que hacer cuando ocurrió una INT1
        bcf PIR6, 0
                         ;Baja bandera INT1IF
        retfie
                                 ;retorno de donde viniste
```

15

# El módulo PPS (Peripheral Pin Select)



- Referencia cap 21 del datasheet
- Módulo encargado de asignar las señales de los periféricos a los pines del microcontrolador.
- Sólo para señales digitales, tanto de entrada como de salida.
- Con este módulo podrás reasignar los pines de los diferentes periféricos que tiene el microcontrolador, limitado a solo lo que indican las tablas 21-1 (entradas) y 21-2 (salidas).

# Ejemplo de PPS aplicado a la INTO



- La INTO tiene por defecto el RBO como puerto de entrada
- Tenemos en el Curiosity Nano un botón en RB4 activo en bajo drenador abierto.
- ¿Cómo haría para que el RB4 sea la INTO del microcontrolador?



17

# Ejemplo de PPS aplicado a la INTO

- Respondiendo a la pregunta:
- Usando el PPS podemos cambiar la asignación por defecto (RBO) de la entrada del INTO hacia el pin RB4 (revisar tabla 21-1 del datasheet)
- El valor obtenido para el registro INTOPPS fue OCH según 21.8.1 del datasheet
- Recordar que INTOPPS se ubica en bank2 (ver sección 21.9 del datasheet)

```
ORG 000000H
                                                 ;Vector de reset
         bra configuro
         ORG 000008H
                                                 ;Vector de interrupcion
         bra INTO_ISR
         ORG 000100H
configuro:
                   movlb 4H
bsf TRISB, 4, 1
                   bcf ANSELB, 4, 1
                                       Importante: combien a bank?
                   bsf WPUB, 4, 1
                   movIb 2H
                   movlw OCH
                                                 ;asignando RB4 para INTO
                   movib 4H
                   bsf PIEO, 0, 1
                                                 ;habilitando INTO (INTOIE=1)
                   movlw 81H
                   movwf INTCON0
                                                 ;GIE=1, INTOEDG=0
inicio:
                   movlb 4H
                                                 ;Rutina principal
                   bra inicio
INTO_ISR:
                                                 ;Rutina de interrupcion
                   ,
retfie
```



# Ejemplo sobre interrupciones

 Realizar dos funciones en el microcontrolador, uno de parpadeo de un LED con periodo de un segundo y otro de función latch de un LED con un pulsador (activo en alto)



# Ejemplo sobre interrupciones

• Hardware:



21

## Ejemplo sobre interrupciones

- El ejemplo es hacer dos cosas aparentemente al mismo tiempo (multi-tarea ó multitasking)
- Estrategias para desarrollar el ejemplo:
  - 1. No utilizar interrupciones (polling high load CPU)
  - 2. Emplear interrupción del TimerO para el parpadeo del LED y en la rutina principal hacer el Latch
  - 3. Emplear interrupción externa INTO para el Latch y en la rutina principal colocar el TimerO
  - 4. Emplear interrupciones tanto para el TimerO como para el Latch (INTO)
    - Se puede interrupciones simples (un solo vector de interrupción)
    - Se puede utilizar prioridades legacy (high priority y low priority con MVECEN=OFF)
    - Se puede usar el VIC (interrupciones vectorizadas con MVECEN=ON)

# Estrategia2: TimerO en interrupción y rutina principal el Latch

- El Timer0 debe de temporizar 1 segundo.
- Empleando el Timer0 en modo 16 bits, prescaler 1:1024, postscaler 1:1, fosc/4, cuenta inicial de 65047 (FE17H)
- Se habilita la interrupción para Timer0 (INTOIE=1)
- No olvidarse del GIE=1



23

```
Estrategia2: Timer0 en interrupción y rutina
principal el Latch
                                                 Nota: No olvidar
                                                 de colocar el bit
                                                 de configuración
                                                                                 bof TRISC, 0, 1

    Código propuesto

                                                                                 bef ANSELC, 0, 1
                                                 MVECEN=OFF
                                                                       29
30
31
                                                                                 bef TRISD, 0, 1
                                                                                 bof ANSELD, 0, 1
             PROCESSOR 18F57Q43
                                                                                 bsf TRISB, 0, 1
             finclude "cabecera.inc"
                                                                                 bcf ANSELB, 0, 1
                                                                                 mowlw 80H
            PSECT upcino, class=CODE, reloc=2, abs
                                                                                 movwf PIE3, 1
                                                                                                   ;TMR0IE=1 (TMR0 interrupt enabled)
                                                                                                   ;GIE=1 (Global interrupt enabled)
             ORG 000000H
            bra configuro
                                                                                                   ; rutina principal
                                                                                btfss PORTB, 0, 1
                                                                                                   ;pregunto si pulse boton
             ORG 000008H
                                ; Vector de interrupcion
                                                                                 bra S-2
                                                                                                   ;no pulse
                                                                                 btg LATC, 0, 1
                                                                                                   ;si pulse y basculo LED
            bra TMR0 ISR
                                                                                 btfsc PORTB, 0, 1
                                                                                                   ;pregunto si solte boton
  11
                                                                                 bra $-2
                                                                                                   :no solte
             ORG 000100H
                                                                                bra inicio
                                                                                                   ;si solte, retorno a inicio
         configuro:
            movlb 0H
                                                                             TMR0 ISR:
                                                                                                   ; rutina de interrupcion para TMRO
             movlw 60H
                                                                                btg LATD, 0, 1
                                                                                                   ;basculo LED
             movwf OSCCON1. 1
                                ;hfintosc, 1:1
                                                                                 movlb 3H
                                                                                                   ;bank3
             movlw 02H
                                                                                 movlw OFEH
  18
             movwf OSCFRQ, 1
                                ;hfintosc 4MHz
                                                                                 movwf TMROH, 1
            movlw 40H
                                                                                 movlw 17H
                                ;hfintosc enabled
                                                                                 movwf TMROL, 1
                                                                                                   ; carga de cuenta inicial a TMRO
  21
             movlb 3H
                                                                                 movlb 4H
                                                                                                   ;bank4
  22
23
             movlw 90H
                                                                                 bcf PIR3, 7, 1
             movwf TOCONO, 1
                                ;tmr0 enabled, 16 bit, posts 1:1
                                                                                 retfie
             movlw 4AH
                                                                                 end upcino
             movwf TOCON1, 1
                               ;fosc/4 presc 1:1024
```

# Estrategia2: Timer0 en interrupción y rutina principal el Latch

Funcionamiento



25

### Estrategia3: Timer0 en rutina principal y Latch con INTO

- En esta estrategia se ha cambiado el modo de trabajo del TimerO a 8bit.
- Recordar que el evento que emite el TMRO en 8bit es debido a la igualdad entre TMROH y TMROL.
- Tener en cuenta que el INTOIE (habilitador de la INTO) se encuentra en el bitO del registro PIE1 y el INTOIF (bandera de la INTO) se encuentra en el bit del registro PIR1



#### Estrategia3: Timer0 en rutina principal y Latch con INTO Código propuesto #include "cabecera.inc" PSECT upcino, class=CODE, reloc=2, abs 32 bef TRISD, 0, 1 ;rd0 salida 5 upcino: bef ANSELD, 0, 1 Nota: No olvidar ;rd0 digital 6 ORG 000000H ; vector de reset bef TRISC, 0, 1 ;rc0 salida bra configuro de colocar el bit bef ANSELC, 0, 1 8 35 :rc0 digital de configuración ORG 000008H bsf TRISB, 0, 1 9 ; vector de interrupcion 36 ;rb0 entrada MVECEN=OFF 10 bra INTO ISR 37 bef ANSELB, 0, 1 ;rb0 digital 11 movlw 01H ORG 000100H 12 movwf PIE1, 1 :INTO enabled 13 configuro: 40 movlw 87H 14 movlb OH :bank0 movwf INTCONO. 1 ;GIE enabled, INTOEDG=1 41 15 movlw 60H ;rd0=0 42 bef LATD, 0, 1 16 movwf OSCCON1, 1 ;hfintosc, 1:1 43 17 movlw 02H 18 movwf OSCFRQ, 1 ;hfintosc 4MHz 45 btfss PIR3, 7, 1 ;pregunto si hubo evento en TMR0 (TMR0IF=1) 19 movlw 40H 46 bra S-2 :no hubo evento en TMRO (TMROIF=0) 20 movwf OSCEN, 1 ;hfintosc enabled 47 btq LATC, 0, 1 ;si hubo evento, basculo rc0 21 movlb 2H ;bank2 48 bef PIR3, 7, 1 ;bajo bandera TMR0IF 22 movlw 08H bra inicio ;repito movwf INTOPPS, 1 23 ;rb0 asignado a INTO 24 movlb 3H ;bank3 INTO ISR: 25 movlw 81H btg LATD, 0, 1 26 ;tmr0 on, 8bit, posts ;basculo rd0 movwf TOCONO, 1 27 53 bef PIR1, 0, 1 ;bajo bandera INTOIF movlw 4AH retfie ; retorno a posicion antes de interrupcion movwf TOCON1, 1 ;fosc4, presc 1:1024 29 movlw 250 movwf TMROH, 1 ;valor de referencia end upcino

27





#### ¿Multitarea?

- Ejecución de varias tareas a la vez en el microcontrolador
- Sistemas RTOS (Real Time Operating System), relacionado con lenguajes de alto nivel generalmente.
- En en assembler la multitarea esta relacionado con el uso de interrupciones.
- Ejecución de una instrucción ≠ ejecución de una tarea



```
Asignación del LB2 (2024-1)
                                                              movlw 03H
    PROCESSOR 18F57Q43
                                                                                                                         movwf TMROL, 1
    #include "cabecera.inc"
                                                              movwf TBLPTRH, 1
                                                                                                                         movlb 4H
                                                   39
                                                              clrf TBLPTRL, 1
                                                                                 :TBLPTR apuntando a 300H
                                                                                                                         btfss PIR3, 7, 1
    PSECT upcino, class=CODE, reloc=2, abs
                                                                                                              76
                                                                                                                        bra $-2
temporal EQU 500H
                       ; GPR
                                                   41
                                                              clrf temporal, 1
                                                                                                                         bcf PIR3, 7, 1
                                                                                                                                            ; termino de TON (20us)
                                                                                                              78
79
                                                                                                                        bof LATE, 0, 1
                                                                                                                                            ;REO a cero
                                                                                 ;rutina principal
                                                                                                                        movlb 3H
    ORG 000000H
                       ; Vector de reset
                                                             movlb 4H
                                                                                                                         movlw OFFH
   bra configuro
                                                             movf PORTB, 0, 1 ;leo RBl y RB0
                                                                                                              81
                                                                                                                        movwf TMROH, 1
                                                                                 ;enmascaramiento
                                                             andlw 03H
                                                                                                                        movlw 4CH
                       ;tabla de decodificacion
                                                             movlb 5H
                                                                                                                         movwf TMROL, 1
ceroaltres: DB 3FH, 06H, 5BH, 4FH
                                                              movwf temporal, 1 ;almacenar en GPR temporal
                                                                                                                        movlb 4H
                                                             call deco7s
                                                                                 ; visualizacion en el displa-
                                                                                                                        btfss PIR3, 7, 1
   ORG 000100H
                                                                                                                        bra S-2
configuro:
                                                             movlw 0
                                                                                                                         bof PIR3, 7, 1
                                                                                                                                            ;termino de TOF (180us
   movlb OH
                                                              cpfseq temporal, 1 ; combinacional 0?
                                                                                                                        bra inicio
    movlw 60H
                                                              bra siguientel
    movwf OSCCON1, 1
                      ;hfintosc, 1:1
                                                             bra estado 0
                                                                                ;salta a combinacional 0
                                                                                                                                            ;duty cycle 30%
   movlw 02H
                                                                                                                        movlb 4H
    movwf OSCFRQ, 1
                       ; hfintosc 4MHz
                                                             movlw 1
    movlw 40H
                                                              cpfseq temporal, 1 ; combinacional 1?
                                                                                                              93
                                                                                                                         movlb 3H
    movwf OSCEN, 1
                       ;hfintosc enabled
                                                              bra siguiente2
                                                                                                                        movlw OFFH
    movlb 3H
                                                                                                                         movwf TMROH, 1
                       ;bank3
                                                             bra estado 1
                                                                                 ;salta a combinacional l
                                                          siguiente2:
                                                                                                                        movlw OC4H
    movwf TOCONO, 1 ;tmr0 on, 16 bit, posts 1:1 61
                                                             movlw 2
    movlw 40H
                                                              opfseq temporal, 1 ; combinacional 2?
                                                                                                                         movlb 4H
                                                                                 ;salta a combinacional 3
    movwf TOCON1, 1
                       ;fosc/4 presc 1:1
                                                                                                                         btfss PIR3, 7, 1
    movlb 4H
                                                                                                                        bra $-2
bcf PIR3, 7, 1
                       ;bank4
                                                             bra estado 2
                                                                                 ; salta a combinacional 2
                       ;REO salida
                                                                                                                                            :termino de TON (60us)
                                                                                                             101
   bcf ANSELE, 0, 1
clrf TRISD, 1
                       ;REO digital
                                                  66
                                                         estado 0:
                                                                                 ;duty cycle 10%
                                                                                                                         bef LATE, 0, 1
                                                             movlb 4H
                       ;RD salida
                                                                                                             103
                                                                                                                        movlb 3H
    clrf ANSELD, 1
                       ;RD digital
                                                             bsf LATE, 0, 1
                                                                                 ;REO a uno
                                                                                                                        movlw OFFH
    setf TRISB, 1
                       ;RB1 y RB0 entradas
                                                   69
                                                             movlb 3H
    movlw OFCH
                                                             movlw OFFH
                                                                                                                        movlw 74H
                                                                                                             106
    movwf ANSELB, 1
                       ;RBl y RBO digitales
                                                             movwf TMROH. 1
```

#### Asignación del LB2 (2024-1) TBLRD\* bof PIR3, 7, 1 ;termino de TOF (140us) movff TABLAT, LATD 112 bra inicio 148 return 114 115 estado\_2: ;duty cycle 80% end upcino movlb 4H ;REO a uno bsf LATE, 0, 1 movlb 3H movwf TMROH, 1 movlw 060H movwf TMROL, 1 movlb 4H btfss PIR3, 7, 1 bof PIR3, 7, 1 ;termino de TON (160us) bof LATE, 0, 1 ;REO a cero movlb 3H movlw OFFH movwf TMROH, 1 movwf TMROL, 1 movlb 4H btfss PIR3, 7, 1 bof PIR3, 7, 1 136 bra inicio ;duty cycle 100% movlb 4H 139 bsf LATE, 0, 1 bra inicio deco7s: ;decodificacion 7seg movlb 4H

33



```
Asignación del LB2 EL52 (2024-1)
                                                                                                                                                                                               btfss PIR3, 7, 1
                                                                                                                                                                                              bra $-2
bcf PIR3, 7, 1
                                                                                                           movf PORTC, 0, 1
andlw 03H
                                                                                                                                                                                                                           ;termino de TOF (300us)
           PSECT upcino, class=CODE, reloc=2, abstemporal EQU 500H ;GPR
                                                                                                                                                                                              bra inicio
mov1b 5H
                                                                                                           movWf temporal, 1
call deco7s
movlb 5H
                                                                                                                                       ;almacenar en GPR tempora 90
;visualizacion en el disp 91
92
                                                                                                                                                                                        estado_1:
movlb 4H
bsf LATB, 0, 1
           upcino:
                                                                                                                                                                                                                           ;RBO a uno
                  ORG OOOOOOH
                                              ;Vector de reset
                                                                                                                                                                                               movlb 3H
                                                                                                           movlw 0
                                                                                                           cyfseq temporal, 1 ;combinacional 0?
bra siguientel ;no, sigue pregunt
bra estado_0 ;salta a combinaci
                                                                                                                                                                                              movlw OFFH
movwf TMROH
movlw OADH
                 ORG 000300H
                                               ;tabla de decodificacion
            ceroaltres: DB 77H, 7CH, 58H, 5EH
                                                                                                                                                                                               movwf TMROL, 1
                                                                                                      siguiente1:
                                                                                                           movlw 1
                                                                                                                                                                                               movlb 4H
btfss PIR3, 7, 1
                                                                                                           cpfseq temporal, 1 ;combinacional 1?
bra siguiente2 ;no, sigue pregunt
bra estado_1 ;salta a combinaci
           configuro:
                                                                                                                                                                                              bcrss PIR3, 7,
bra $-2
bcf PIR3, 7, 1
bcf LATB, 0, 1
                 movlb 0H
movlw 60H
movwf OSCCON1, 1
movlw 02H
                                              :bank0
                                                                                                     siguiente2:
                                                                                                                                                                                                                           ;RBO a cero
                                             ;hfintosc, 1:1
                                                                                                           movlw 2
                                                                                                                                                                                              movlb 3H
                                                                                                           cpfseq temporal, 1 ; combinacional 2?
bra estado_3 ; salta a combinacio
bra estado_2 ; salta a combinacio
                                                                                                                                                                                              movlw OFFH
                  movwf OSCFRQ, 1
                                              :hfintosc 4MHz
                                                                                                                                       ;salta a combinacional 3
;salta a combinacional 2
                 movlw 40H
movwf OSCEN, 1
movlb 3H
                                               ;hfintosc enabled
                                                                                                                                                                                              movwf TMROL, 1
movlb 4H
                                               ;bank3
                                                                                                                                       :duty cycle 10%
                 movlw 90H
                                                                                                                                                                                              btfss PIR3, 7, 1
bra $-2
bcf PIR3, 7, 1
bra inicio
                                                                                                           movlb 4H
bsf LATB, 0, 1
movlb 3H
movlw 0FFH
                                              tmr0 on, 16 bit, posts 1:1
                                                                                                                                       :RBO a uno
                                                                                                                                                                                                                           ;termino de TOF (250us
                 movwf TOCON1, 1
                                              :fosc/4 presc 1:1
                 movlb 4H
                                               ;bank4
                 bcf TRISB, 0, 1
bcf ANSELB, 0, 1
clrf TRISD, 1
                                               ;RBO salida
;RBO digital
;RD salida
                                                                                                           movlw ODFH
                                                                                                                                                                                        estado 2:
                                                                                                                                                                                                                           :duty cycle 80%
                                                                                                           movWf TMR0L, 1
movlb 4H
btfss PIR3, 7, 1
                                                                                                                                                                                              movlb 4H
bsf LATB, 0, 1
movlb 3H
                 clrf ANSELD, 1
setf TRISC, 1
movlw 0FCH
                                               :RD digital
                                               ;RC1 y RC0 entradas
                                                                                                                                                                                              movlw OFFH
                                                                                                           bcf PIR3, 7, 1
bcf LATB, 0, 1
movlb 3H
movlw OFEH
                                                                                                                                                                                              movwf TMROH, 1
movlw 22H
movwf TMROL, 1
movlb 4H
                                                                                                                                        :termino de TON (33us)
                                              ;RC1 y RC0 digitales
                 movwf ANSELC, 1
                 clrf TBLPTRU, 1
                 movlw 03H
movwf TBLPTRH, 1
clrf TBLPTRL, 1
                                                                                                                                                                                              btfss PIR3, 7, 1
                                              ;TBLFTR apuntando a 300H
                                                                                                           movlw OD4H
                                                                                                                                                                                              bra $-2
bcf PIR3, 7, 1
                  movlb 5H
                                                                                                                                                                                                                           :termino de TON (222us)
```

```
Asignación del LB2 EL52 (2024-1)
                      bcf LATB, 0, 1
                      movlb 3H
                      movlw OFFH
          129
                      movwf TMROH, 1
                       movlw 91H
                      movwf TMROL, 1
                                                                             162
                                                                                      deco7s:
                                                                                                             ;decodificacion 7seg
          131
                       movlb 4H
                      btfss PIR3, 7, 1
          133
                                                                             164
                                                                                          movff temporal, TBLPTRL
                      bra $-2
bcf PIR3, 7, 1
                                                                             165
                                         ;termino de TOF (111us)
                                                                                          movff TABLAT, LATD
          135
                                                                             166
                      bra inicio
                                                                             167
                                                                                          return
          137
          138
                   estado 3:
                                         :duty cycle 100%
                                                                             169
                                                                                          end upcino
                      movlb 4H
                      bsf LATB, 0, 1
          140
                                         :RBO a uno
                      movlb 3H
          142
                      movlw OFEH
                      movlw 0D4H
          144
                       movwf TMROL, 1
                      movlb 4H
          146
          147
148
                      btfss PIR3, 7, 1
                      bra $-2
          149
                      bcf PIR3, 7, 1
                                         ;termino de TON (300us)
                      bcf LATB, 0, 1
                                         ;RBO a cero
          151
                      movlb 3H
                      movlw 0FFH
          153
                      movwf TMROH, 1
          154
                       movlw ODFH
                      movwf TMROL, 1
          155
          156
                       movlb 4H
                      btfss PIR3, 7, 1
          157
                      bra $-2
bcf PIR3, 7, 1 ;termino de TOF (331s)
          158
          159
          160
                      bra inicio
```

| Fin de la | sesión |  |  |
|-----------|--------|--|--|
|           |        |  |  |
|           |        |  |  |
|           |        |  |  |